package selectsort;
/**
 * 选择排序selectionSort
 */
public class SelectionSort {

    /*
     * 找到素组中最小的那个元素，放到第一号位置
     * 循环就ok
     */

    //https://www.bilibili.com/video/BV1954y187Nz?p=3

    public static void main(String[] args) {

        int[] arr = new int[]{5, 3, 6, 8, 1, 7, 9, 4, 2};

        System.out.println("初始数组：");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+" ");
        }

        // 核心
        for (int i = 0; i < arr.length; i++) {
            // 选择一个元素作为做小的下标
            int minPosition = i;
            // 在该元素后一个开始，遍历数组，比较每个和他的大小
            // 如果该元素比‘选定的’还要小，就把minPotion给他，
            // 目的：就是为了找出数组中最小的那个元素的下标索引
            for (int j = i+1; j < arr.length; j++) {
                if (arr[j] < arr[minPosition]) minPosition = j;
            }

            System.out.println("\nminposition:" + minPosition);
            // 调换元素
            int temp = arr[i];
            arr[i] = arr[minPosition];
            arr[minPosition] = temp;
        }

        System.out.println("结束数组：");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+" ");
        }

    }

}
